草庐IT

python - JSON序列化MongoDB

全部标签

ruby-on-rails - 渲染联接模型及其关联模型的JSON对象

在Rails(4.1.5/ruby​​2.0.0p481/win64)应用程序中,我在Student和Course之间建立了多对多关系,并表示了该关联的联接模型StudentCourse并具有和附加属性,称为start(set默认情况下为“false”)。我还在由student_id和course_id组成的联接表中添加了一个索引,并对此设置了唯一的检查,就像这样t.index[:student_id,:course_id],:unique=>true,:name=>'by_student_and_course'我希望将其用作复合主键,但是由于在Rails中没有复合主键(不使用gem)

ruby-on-rails - 在一个 Rails 应用程序中使用 PostgreSQL 的 MongoDB

我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多

ruby-on-rails - 给定一个 json 对象,如何在 rails 中遍历该对象

我的应用程序正在将以下json对象发布到Rails。[{\"completed\":false,\"id\":196,\"position\":0,\"title\":\"Item1\",\"updated_at\":\"2011-08-03T21:17:09Z\"},{\"completed\":false,\"id\":193,\"position\":1,\"title\":\"ItemX\",\"updated_at\":\"2011-08-03T21:16:19Z\"},{\"completed\":false,\"id\":197,\"position\":2,\"titl

ruby-on-rails - Rails 中字段的自定义序列化

有没有一种方法可以对Rails中的字段进行自定义序列化,一种在保存和加载字段时运行的方法,用于将最终保存在数据库中的字符串转换为字符串/转换为字符串。具体来说,我想要做的是有一个类型符号的字段,如性别,可能的值是:男性和:女性,在数据库中存储“男性”和“女性”。有一些解决方法,例如:defgenderread_attribute(:gender).try(:to_sym)end但这会使obj.attributes保持不变,因此这是一个有漏洞的抽象。 最佳答案 您可以在Rails3.1中做到这一点。您要序列化的对象必须响应load和d

ruby - 使用 mongodb/mongoid 运行时更改模型

我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序

ruby-on-rails - Rails/Rspec JSON 整数在测试后调用时被转换为字符串

我正在测试对我们API的JSON请求,它将以JSON响应。似乎JSON中的所有整数都被转换为字符串,因为我们将它们发布到Controller考虑操作。Controllerdefconsiderbinding.pry#bindingno#2usedtochecktheparamsafterpostfromtest.ifParametersValidator.is_valid?(params)application_handler=ApplicationHandler.new(request_interactor)renderjson:application_handler.resulte

ruby - 将 Ruby 数组解析为 JSON

我有一些结果:putsresult看起来像这样的输出:Allowed208639631554906Denied36073250Quarantined1562400调试presults输出[["Allowed",20863963,1554906],["Denied",3607325,0],["Quarantined",156194,0]]标题是:status,hits,page_views我需要将其转换为json。如果结果是标准的csv格式,那么它会很简单,但如果结果格式如上所示,人们将如何处理呢?预期输出类似于此:[{"status":"Allowed","hits":"2086396

ruby-on-rails - 我如何从 Ruby 代码连接到 mongodb?

我如何从Ruby代码连接到mongodb? 最佳答案 首先,您必须安装MongoDbgem:geminstallmongo然后运行代码:require'rubygems'#notnecessaryforRuby1.9require'mongo'db=Mongo::Connection.new.db("mydb")#ORdb=Mongo::Connection.new("localhost").db("mydb")#ORdb=Mongo::Connection.new("localhost",27017).db("mydb")

ruby - 在嵌套对象中使用自定义 to_json 方法

我有一个使用Ruby标准库中的Set类的数据结构。我希望能够将我的数据结构序列化为JSON字符串。默认情况下,Set序列化为数组:>>s=Set.new[1,2,3]>>s.to_json=>"[1,2,3]"这很好,直到您尝试反序列化它。所以我定义了一个自定义的to_json方法:classSetdefto_json(*a){"json_class"=>self.class.name,"data"=>{"elements"=>self.to_a}}.to_json(*a)enddefself.json_create(o)newo["data"]["elements"]endend哪个

ruby - MongoDB:无法从 BSON 类型 EOO 转换为 Date

我正在尝试使用聚合框架(使用ruby​​)并像这样投影日期:db['requests'].aggregate([{"$project"=>{_id:0,method:'$method',user:'$user',year:{'$year'=>'$timestamp'}}}])文档是这样的:{_id:ObjectId("5177d7d7df26358289da7dfd"),timestamp:ISODate("2013-04-12T03:58:05+00:00"),method:"POST",status:"200",inputsize:"874",outputsize:"4981",u